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APPARATUS AND METHOD FOR WEB-BASED TOOL MANAGEMENT 

TECHNICAL FIELD 

The present invention relates in general to data processing systems, and in 
particular, to data processing systems for managing manufacturing equipment via the 
web. 

BACKGROUND INFORMATION 

Modern manufacturing facilities rely on highly automated tools to implement 
the manufacturing process. For example, semiconductor fabrication ("fab") facilities 
incorporate highly automated tool sets for the processing of semiconductor wafers. 
Process control and monitoring is mediated through a set of software methods which 
may be invoked to implement the processes and monitoring to be performed. The 
control and monitoring software run on a tool server which may be coupled to the 
tools via a plurality of ports, each of which interfaces the tool server with a particular 
tool, in point-to-point fashion. Alternatively, the tools in the tool server may reside 
on a Local Area Network (LAN), To control the manufacturing process, a user must 
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be able to communicate with the tool server, either via a user system resident on the 
LAN, or otherwise in communication with the tool server. In particular, remote 
access to the tool server for control and monitoring of the status of a tool, to the 
extent that it exists at all, requires the development of specialized code implemented 
on each platform for which remote access is to be provided. Thus, there is a need in 
the art for methods and apparatus for providing remote tool management capabilities. 
In particular, there is a need in the art for apparatus and methods for providing remote 
tool management without the necessity for developing specialized, platform 
dependent software. 
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SUMMARY OF THE INVENTION 

The aforementioned needs are addressed by the present invention. 
Accordingly, there is provided, in a first form, a method of tool management. The 
5 method includes receiving a request over a network. A request type is determined 

from a predetermined portion of the request. In response to the request and the type 
of the request, a message is sent to the tool, which message is operable for controlling 
an operation of the tool. 

There is also provided, in a second form, a data processing system. The 

10 system includes circuitry operable for receiving a request via a network. The system 

also includes circuitry operable for determining a type of the request using a 
predetermined field in a portion of the request, and circuitry operable for sending a 
message to a tool in response to the first request and the type of the request. The 
message is operable for controlling an action of the tool. 

1 5 Additionally, there is provided, in a third form, a program product embodied 

in a tangible storage medium. The program contains programming for tool 
management and includes instructions for receiving a request over a network. A 
request type is determined from a predetermined portion of the request. Also included 
are instructions for sending a message to the tool in response to the request and the 

20 type of the request, which message is operable for controlling an operation of the tool. 
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The foregoing has outlined rather broadly the features and technical 
advantages of the present invention in order that the detailed description of the 
invention that follows may be better understood. Additional features and advantages 
of the invention will be described hereinafter which form the subject of the claims of 
the invention. 
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BRIEF DESCRIPTION OF THE DRAWINGS 

For a more complete understanding of the present invention, and the 
advantages thereof, reference is now made to the following descriptions taken in 
5 conjunction with the accompanying drawings, in which: 

rl FIGURE 1 illustrates, in block diagram form, a data processing network in 

% accordance with an embodiment of the present invention; 

*9 FIGURE 2 illustrates, in block diagram form, a data processing system which 

p may be used in a client and a server of FIGURE 1 ; 

% 1 0 FIGURE 3 illustrates, in flow chart form, a hypertext transfer protocol 

(HTTP) server methodology in accordance with an embodiment of the present 
fu invention. 

E FIGURE 4 illustrates, in flow chart form, a security server methodology 

y which may be used with the HTTP server process of FIGURE 3 ; 

1 5 FIGURE 5 illustrates, in flow chart form, a process for generating responses to 

HTTP requests received in accordance with the HTTP methodology of FIGURE 3; 

FIGURE 5.1 illustrates a graphical user interface (GUI) representation of a 
tool object model which may be used in the HTTP request process of FIGURE 5; 
FIGURE 5.2 illustrates, in flow chart form, an exemplary process control 
20 methodology which may be used with the present invention; 
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FIGURES 6.1 and 6.2 illustrate displays associated with an information 
request in accordance with the principles of the present invention; 

FIGURES 7. 1 and 7.2 illustrate displays associated with an edit request in 
5 accordance with the principles of the present invention; 

FIGURES 8. 1 and 8.2 illustrate displays associated with an expand request in 
accordance with the principles of the present invention; 

FIGURES 9. 1 and 9.2 illustrate displays associated with an execute request in 
accordance with the principles of the present invention; 
10 FIGURES 10.1 and 10.2 illustrate displays associated with an information 

request for a method history in accordance with the principles of the present 
invention; and 

FIGURE 1 1 illustrates, in flow chart form, a service method override process 
in accordance with an embodiment of the present invention. 

15 
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DETAILED DESCRIPTION 

In the following description, numerous specific details are set forth such as 
specific word or byte lengths, etc. to provide a thorough understanding of the present 

5 invention. However, it will be obvious to those skilled in the art that the present 

invention may be practiced without such specific details. In other instances, 
well-known circuits have been shown in block diagram form in order not to obscure 
the present invention in unnecessary detail. For the most part, details concerning 
timing considerations and the like have been omitted in as much as such details are 

1 0 not necessary to obtain a complete understanding of the present invention and are 

within the skills of persons of ordinary skill in the relevant art. 

Refer now to the drawings wherein depicted elements are not necessarily 
shown to scale and wherein like or similar elements are designated by the same 
reference numeral through the several views. 

1 5 The present invention provides a mechanism for managing automated 

manufacturing tools and processes via an Internet worked data processing system. 
Remote interactions between a client and a processing tool are provided using 
standard Internet protocols and facilities. These may include the hypertext transfer 
protocol (HTTP), the hypertext markup language (HTML), and Extensible Markup 

20 Language (XML). The present invention enables users to interact with an automated 

tool using a standard web browser running on a client data processing system. The 
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user may, for example, query and change the status and configuration of the 
automated tool, and command it to perform activities, such as in a semi-conductor 
fabrication environment, for example, to begin processing material. The present 
invention also allows users to interact with a station controller interfaced to the tool, 
5 querying and changing the configuration and status of the station controller, and 

instructing the controller to perform various activities, for example, performing a 
logging or reporting function. Additionally, the methods and apparatus of the present 
invention include web server functionality, obviating the need to configure and 
administer a separate web server. 

10 Refer now to the drawings, wherein depicted elements are not necessarily 

shown to scale and wherein like or similar elements are designated by the same 
reference numeral through the several views. 

FIGURE 1 illustrates a representative network environment which may be 
used with the present invention. A plurality of clients 112-115 facilitate user 

1 5 interactions with a plurality of automated manufacturing tools 111. Within 

clients 1 12-1 15, the tool management facilities are provided via a standard web 
browser. Such web browsers are known in the data processing art, and include, for 
example, Netscape Navigator®, a product of Netscape Communications Corporation, 
and Internet Explorer, a product of Microsoft Corporation. Interactions between 

20 users, one of clients 1 12-115 and tools 1 1 1 are mediated via server 1 10 which 
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implements the methodologies of the present invention, further described below in 
conjunction with FIGURES 3-6. 

Clients 1 12-1 1 5 are networked with server 110. Clients 1 12 and 1 13 are 
networked via LAN 122. Clients 1 14 and 1 1 5 are networked via the Internet. 

5 Clients 1 14 and 1 15 communicate via a facility having a presence on the Internet, 

here generically referred to as an Internet Service Provider (ISP) 118. Additionally, 
server 110 interfaces with the Internet via an ISP 1 1 8. Note that clients need not rely 
on a wired connection but may be a wireless device. Wireless clients could, for 
example, include a conventional personal computer and wireless modem or even a 

10 web capable cellular telephone. Each ISP 1 18 is coupled to Internet backbone 120. 

Alternatively, a manufacturing facility may itself have a presence on the Internet, and 
in such an alternative embodiment of the networking environment in FIGURE 1, 
server 1 10 may incorporate hardware for connecting to Internet backbone 1 12. 
Information may be exchanged between clients 1 12-1 15 and server 1 12 using the 

1 5 hypertext transfer protocol (HTTP). Additionally, the data constituting the 

information for managing tools 1 1 1 to be exchanged between clients 1 12-1 15 and 
server 1 10 may be communicated using the transmission control protocol 
TCP/Internet Protocol (TCP/IP). TCP/IP is a standard communication protocol on 
the Internet. 

20 Additionally, server 1 10 is networked with tools 1 1 1 and provides tool 

management information thereto in response to the user input received via 
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clients 1 12-1 15. In the exemplary embodiment of FIGURE 1, server 1 10 is 
connected to tools 1 1 1 via LAN 124. Alternatively, tools 1 1 1 may reside on 
LAN 122. However, in such an alternative embodiment, tool management operations 
by users on clients 1 12 and 1 13 would still be mediated via server 1 10 through the 
5 standard web browser on clients 112 and 1 13. 

FIGURE 2 illustrates a block diagram of a representative data processing 
system 200. Data processing system 200 may be used to implement clients 1 12-115. 
Additionally, data processing system 200 may be used in an implementation of 
server 1 10 by incorporating software which performs the methodologies of the 

10 present invention as described further below. The system has a central processing 

unit (CPU) 210, which is coupled to various other components by system bus 212. 
Read-only memory ("ROM") 216 is coupled to the system bus 212 and includes a 
basic input/output system ("BIOS") that controls certain basic functions of the data 
processing system 200. Random access memory ("RAM") 214, I/O adapter 218, and 

15 communications adapter 234 are also coupled to the system bus 212. I/O adapter 218 

may be a small computer system interface ("SCSI") adapter that communicates with a 
disk storage device 220. Communications adapter 234 interconnects bus 212 with an 
outside network enabling the data processing system to communicate with other such 
systems. Input/Output devices are also connected to system bus 212 via user interface 

20 adapter 222 and display adapter 236. Keyboard 224, track ball 232, mouse 226 and 

speaker 228 are all interconnected to bus 212 via user interface adapter 222. Display 
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monitor 238 is connected to system bus 212 by display adapter 236. In this manner, a 
user is capable of inputting to the system throughout the keyboard 224, trackball 232 
or mouse 226 and receiving output from the system via speaker 228 and display 238. 

Preferred implementations of the invention include implementations as a 
computer system programmed to execute the method or methods described herein, 
and as a computer program product. According to the computer system 
implementation, sets of instructions for executing the method or methods are resident 
in the random access memory 214 of one or more computer systems configured 
generally as described above. Until required by the computer system, the set of 
instructions may be stored as a computer program product in another computer 
memory, for example, in disk drive 220 (which may include a removable memory 
such as an optical disk or floppy disk for eventual use in the disk drive 220). Further, 
the computer program product can also be stored at another computer and transmitted 
when desired to the user's work station by a network or by an external network such 
as the Internet. One skilled in the art would appreciate that the physical storage of the 
sets of instructions physically changes the medium upon which it is stored so that the 
medium carries computer readable information. The change may be electrical, 
magnetic, chemical, biological, or some other physical change. While it is convenient 
to describe the invention in terms of instructions, symbols, characters, or the like, the 
reader should remember that all of these and similar terms should be associated with 
the appropriate physical elements. 
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Note that the invention may describe terms such as comparing, validating, 
selecting, identifying, or other terms that could be associated with a human operator. 
However, for at least a number of the operations described herein which form part of 
at least one of the embodiments, no action by a human operator is desirable. The 
operations described are, in large part, machine operations processing electrical 
signals to generate other electrical signals. 

Refer now to FIGURE 3 illustrating an HTTP server methodology 300 in 
accordance with the principles of the present invention. Methodology 300 may be 
incorporated, for example on server 1 10 in FIGURE L In step 302, HTTP server 
methodology 300 waits for a connection request on a TCP/IP socket. This is the idle 
state for HTTP server methodology 300. An artisan of ordinary skill in the art would 
understand a socket to be a virtual port that enables clients, such as clients 1 12-1 15, 
FIGURE 1, to connect to a server, such as server 110. In an embodiment of the 
present invention, the Internet Protocol (IP) address and port number for the socket 
are configurable. A client communicates information to server methodology 300 by 
specifying the preselected values of the IP address and the port number. On receipt of 
a connection request 304, a new socket is generated, step 306. Alternatively, a pool 
of sockets may be created, and a socket retrieved from the available pool. In step 308, 
a connection is established on the new socket created, or alternatively, retrieved, in 
step 306. In step 310, subprocess 301b waits for an HTTP request Additionally, a 
timer is running whenever methodology 300 is waiting for an HTTP request. If the 
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timer expires, step 3 1 1, the correction is deemed to have been broken, and the socket 
opened in step 308, is closed, step 313. 

Upon arrival of an HTTP request, 3 12, it is then determined if the request is 
from an authorized user, step 314. A security server process for performing step 3 14 
will be described in detail in conjunction with FIGURE 4. 

If, in step 3 14, the user is valid, HTTP requests 3 12 is passed to a page server, 
step 3 1 6. The process by which a page server handles the HTTP request will be 
described in detail in conjunction with FIGURE 5. Note that a plurality of page 
servers may be running concurrently, for example, as multiple threads within 
methodology 300. In this way, methodology 300 may handle multiple requests. The 
appropriate page server may be determined in an embodiment of the present invention 
by the data passed in a Uniform Resource Locator (URL). URLs are a string 
representation of a resource available via the Internet. The syntax and semantics for 
URLs are defined in accordance with an Internet protocol standard in Request for 
Comments (RFC) 1738, which is hereby incorporated herein by reference. A portion 
of the URL is referred to as the "url-path". The url-path supplies the details of how a 
resource can be accessed. The syntax of the url-path is a sequence of alphanumeric 
strings separated by the V" ("forward slash"). 

In an embodiment of the present invention, the url-path of HTTP request 3 12 
is used to determine the page server that will be invoked upon receiving the request, 
and specify the functions being requested and the object upon which the functions 
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will be performed. A url-path, in accordance with the principles of the present 
invention may have the form; /dir 0 /dir 1 /dir 2 .... 

The "diii" values serve a similar function as directories do in a computer's 
local file system. The first directory, M dir 0 H ? is used to determine which page server 
will be invoked in step 3 16 to service the HTTP request. In other words, the 
particular value of n dir 0 " received in HTTP request 3 12 specifies the particular page 
server that will service the request. Page servers register themselves with 
methodology 300 during initialization. Initialization typically occurs when the 
program starts, usually a result of a static configuration read from a file or database. 
However, initialization may also occur, for example, in response to adding a new 
module to the equipment wherein the corresponding page server is configured and 
initialized dynamically. On registering, the page server provides the name of the 
directory the particular page server will "serve". Additionally, a brief description is 
also provided that is used to generate a "home page" for the tool corresponding to the 
particular page server. The "home page" allows users to access the tool management 
facilities using a conventional web browser. This will be discussed further in 
conjunction with FIGURE 5 hereinbelow. 

The page server invoked in step 316 generates a reply to HTTP request 3 12. 
This will also be discussed further in conjunction with FIGURE 5. The reply is 
passed to methodology 300 which sends the reply in step 318. The reply may take a 
finite amount of time to send due to delays arising from available network resources, 
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or transmission errors, for example. In step 321 methodology 300 waits for the send 
to complete. On completion, methodology 300 closes the socket opened/retrieved in 
step 306 and notifies client that send is complete. 

Refer now to FIGURE 4 illustrating a security server process which may be 
used to implement step 3 14 in methodology 300. In step 402 it is determined if a 
cookie is received in the header of the HTTP request. If not, a login page is presented 
in step 404. If, however, a cookie is received in the HTTP header, in step 406 the 
user name is extracted and compared with a list maintained by the server. 

In step 408 is determined if the user is known. If a cookie has been received, 
and the user name extracted in step 406 compares with one of the names in the list, or 
if the user name and password received via the login page presented in step 404 
compare with an entry in the list maintained by the server, then step 408 proceeds by 
the yes branch to step 410. In step 410, if a cookie was not received in step 402, that 
is the user logon via the login page presented in step 404, the user's browser is 
requested to set a cookie of the same name as the tool in the HTTP request, in which 
the cookie contains the user's name. Subsequent HTTP request will then contain the 
cookie in the header, and in servicing that request, methodology 300, FIGURE 3, via 
step 3 14 would proceed by the yes branch in the corresponding step 402. If, in 
step 408 the user was not recognized, then access fails, and in step 320, FIGURE 3, a 
request denied message is generated, and sent in step 318. 
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In step 412 it is determined if a check activity option is active. The check 
activity option automatically logs out a user that has been inactive for a preselected 
interval of time. If, in step 412, activity checking is enabled, then, in step 414 it is 
determined if the user has had recent activity. That is, if the user has been active prior 
5 to the expiration of the preselected time interval for automatically logging out users. 

If the user has not been recently active, then access fails, and, in step 320, FIGURE 3, 
a request denied message is generated, and sent to the user in step 318, FIGURE 3 . 

If, however, in step 414 the user has generated activity within the preselected 
time interval, the contact time maintained in the server database is updated, step 416 

1 0 and the current HTTP request is passed to the page servers, step 316, FIGURE 3 . 

Furthermore, if, in step 412, activity checking is disabled, step 414 is bypassed, and 
methodology 300 implementing authentication checking in accordance with the 
embodiment of step 314 in FIGURE 4 proceeds directly to step 416 to update the 
contact time in the server database entry corresponding to the current user. 

1 5 Refer now to FIGURE 5 illustrating a page server methodology 500 in 

accordance with the embodiment of the present invention. Page server 
methodology 500 may receive an HTTP request from step 3 16 of methodology 300, 
FIGURE 3. 

In step 502 the HTTP request is inspected to determine the function to be 
20 performed. Because it is difficult to maintain accurate information about a client 

browser's session with an HTTP server, the functions that page server process 500 
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perform may only depend on the information passed in the HTTP request. The fields 
available in the HTTP request to store this information are, principally, are the URL, 
and the search (or query) field. In an embodiment of the present invention in 
accordance with page server process 500, FIGURE 5, the URL is used to describe the 
functions the page server is to perform. 

As previously described in conjunction with FIGURE 3, the url-path in the url 
field in an HTTP request has the approximate form /diro/dkydky... . The field 
labeled "dir 0 " has a predetermined name which, appearing in a url-path informs the 
HTTP server process to invoke a page server process, in accordance with, for 
example, step 3 16 in FIGURE 3 . In an embodiment of the present invention, the 
string "Explorer" may be used to invoke the page server process, however, a artisan of 
ordinary skill in the art would understand that another predetermined term in the 
"dir 0 " field of the url-path could be used, and such alternative embodiments would be 
within the spirit and scope of the present invention. 

The next field, "dny may contain the "name" or similar designator of the 
function that is being requested. Thus, the function may be determined, in such an 
embodiment, in step 502 by inspecting the field " dirx" in the url-path of the url in the 
HTTP request. Additionally, the field "dir 2 " may contain the name or other identifier 
of the object upon which the function will be performed. An object identifier may 
simply be an assigned number which might, in an embodiment of the present 
invention start at one, or other predetermined value, and consecutively number the 
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objects. Alternatively, the "fully qualified" object name (analogous to a fully 
qualified path name) may be used to build a hash table with the key being the hash of 
the object name and the value a pointer to the object, and the key serves as the object 
identifier. It would be understood by an artisan of ordinary skill that such alternative 
embodiments are within the spirit and scope of the present invention. The remaining 
fields in the url-path portion of the URL in the HTTP request may include additional 
function-specific information. These will be described further below. 

Refer now to FIGURE 5.1 illustrating a tool object model 550 which may be 
used with the present invention. Object model 550 is in accordance with a tool object 
promulgated by Brook Automation, Inc. However, it would be understood by an 
artisan of ordinary skill in the tool automation art that the principles of the present 
invention may be used with other tool object models in the same fashion. Tool object 
model 550 provides a logical description in the automatic control environment of a 
physical tool "on the factory floor." As indicated in Inset A, showing the generic 
format for describing the organization of tool object model 550, a property 552 is a 
collection of one or more objects 554; the "filled circle" denoting "collection." Thus, 
tool object model 550 includes a collection of one or more tool objects 556. 
Likewise, tool object 556 includes dictionaries 558 and resources 560. 
Dictionary 558 is a collection of dictionary objects 562 which, itself, includes a 
collection of data definition objects 564, A data definition object defines a data 
structure, and may be viewed as a type statement analogous to a "typedef ' in the C 
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programming language. Resources 560 include a collection of one or more resource 
objects 566. Resource object 566 includes a collection of service objects 568. 

Each service object 568 includes attributes 570, methods 572 and events 574. 
Attributes, which are defined as a collection of attribute objects 576 that a collection 
of one or more attribute objects 576. Methods 572 include a plurality of method 
objects 578. Method objects 578 perform the functionality in the management of the 
physical tool. Method objects 578 include error objects 580 for error reporting, and, 
in the typical fashion, inputs 582 and 584, each of which is defined to be a collection 
of one or more data item objects 586. A data item object 586 may be an actual value 
of a variable or parameter. Events 574 constitute a collection of one or more event 
objects 588, each of which includes an output which is a collection of one or more 
data item objects 586. Examples of attributes, methods and events will be described 
hereinbelow. 

The functions that the page server may perform include an information 
function, an editing function, an execution function, and an expanding function. 
(These may be denoted "INFO", "EDIT", "EXECUTE" and "EXPAND" ) Each of 
these will be discussed below. 

The INFO function provides detailed information about the current attributes 
of a selected object. The INFO function is invoked, step 504, in response to a 
corresponding first predetermined value in field "diii" representing the designator of 
the function being invoked. For example, the first predetermined value may be the 
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string "Info" but other values would be used, as would be recognized by an artisan of 
ordinary skill In response, INFO pages 506 containing the information about the 
attributes of the object (identified in field M dir 2 " of the URL) are returned to the client 
browser, step 508. Page server methodology then exits, step 510 by returning to 
5 step 321 of HTTP server process 300. At step 321, HTTP server process 300 waits 

for the send to complete, and then returns to step 302, for the next connect request. 

This may be understood by referring to FIGURE 6.1 illustrating an exemplary 
display 602 for Generic tool tool object 604. Display 602 has been expanded to show 
child dependencies from root objects, as will be discussed in detail hereinbelow in 

10 conjunction with FIGURES 8.1 and 8.2, The dictionary object 606 includes Generic 

tool Dictionary 608. Within the Generic tool Dictionary 608, there are a plurality of 
data definition objects 610 including the SEMI equipment communication standard 
(SECS) 612. SECS 612 itself includes a plurality of data items 614. Event reporting 
data item 616 includes a set of collection event items 618 and a set of report 

15 variables 620. 

Information about a tool object may be obtained by sending a corresponding 
HTTP request to HTTP server process 300, FIGURE 3. HTTP server process 300 
then passes the request to the page server process as previously described. Otherwise, 
it would be too time consuming to download all of the details of every tool object in a 

20 large tool object model to a browser, and too error-prone to try to synchronize 

dynamic attributes of the object model between a client and the server. 
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Information about an object is obtained by sending an HTTP request to HTTP 
server methodology 300, FIGURE 3. An information HTTP request has a first 
predetermined value in the "dhV* field of the URL-path. For example, the first 
predetermined value may be the string "Info". However, it would be understood by 
an artisan of ordinary skill that other predetermined values may be used in accordance 
with the principles of the present invention, and such alternative embodiments would 
be within the spirit and scope of the present invention. HTTP server 
methodology 300 passes the request to page server process 500, as previously 
described hereinabove. Referring again to FIGURE 5, inspect function step 502 uses 
the value in the "diri" field of the URL-path of HTTP request 3 12, corresponding to 
the information request, to pass the request to information step 504. Step 504 uses the 
value in the "dir 2 ", the object ID to generate the corresponding information page 506 
and send the page to the client in step 508. An information HTTP request may be 
initiated by selecting the object for which the detailed information is sought by 
selecting the object on the web browser display. Thus, in exemplary display 602, 
chamber location process variables item 622, shown highlighted in FIGURE 6.1, has 
been selected. An object may be selected by "clicking" on the object on the display 
with a user input device, such as mouse 226, FIGURE 2. 

In response to the information HTTP request, as previously described, page 
server process 500 generates the corresponding web page containing the detailed 
information for the selected object. FIGURE 6.2 illustrates exemplary information 
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display 624 corresponding to chamber location process variables item 622, 
FIGURE 6. 1 . Exemplary information display 624 is with reference to the SECS, 
however, an ordinarily skilled artisan would understand that the principle of the 
present invention do not rely on the SECS, and tool objects implemented in 
accordance with another set of protocols may return different information. 
Nevertheless, the principles of page server process 500 would operate in the same 
fashion, and such alternative embodiments would be within the spirit and scope of the 
present invention. 

Refer now to FIGURES 7. 1 and 7.2 illustrating an exemplary display which 
may be shown on a client GUI in association with an edit attribute page 573, 
FIGURE 5, generated by page server process 500. Display 702 shows a tool 
management resource directory 704 including tool object 706. Tool object 706 
provides a plurality of services that may be accessed using the principles of the 
present invention. Attributes of the services provided by the tool via the tool object 
model are also shown in display 702. Attributes 710 of GEM clock 708 are 
displayed, and include a time formatting attribute 712, shown highlighted in 
FIGURE 7.1. (" GEM" denotes the Generic Model for Communications and Control 
of SEMI Equipment standards promulgated by Semiconductor Equipment and 
Materials International (SEMI). SEMI is a global trade association that represents the 
semiconductor and flat panel which promulgates standards for ensuring compatibility 
equipment automation standards, such as GEM. Exemplary embodiments will be 
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described in the context of automated fabrication ("fab") facilities in the 
semiconductor industry. Nevertheless, it would be understood by an ordinary skilled 
artisan that the principles of the present invention may be used in the same fashion 
with other automated manufacturing processes.) 

Attributes of objects may be modified using the principles of the present 
invention. An attribute may be modified by the client sending an EDIT request in an 
HTTP request 3 12, FIGURE 3. As previously described, page server process 500 
inspects HTTP request 3 12 in step 502. If the HTTP request includes an edit request, 
determined in step 502 by inspecting the "dhy' field, for a second predetermined 
value, then in step 512, an edit method is invoked and an edit attribute page 512, is 
sent, step 508. The second predetermined value may be the string "Edit," however, an 
artisan of ordinary skill would understand that other values may be used. 
Additionally, the "dir 2 " field may include the name of the variable being edited. 

FIGURE 7.2 illustrates a graphical display 703 of an edit response in 
accordance with the principles of the present invention. Display 703 corresponds to 
the exemplary sixteen character time format attribute 712 of FIGURE 7.1. 
Description field 714 describes the particular attribute. Name field 716 displays the 
name of the attribute, which reflects the attribute name appearing in the 
corresponding display 702. Read-Only field 718 displays the value of a Boolean 
"Read-Only" value. If the value displayed in Read-Only field 718, then the value of 
the attribute may not be changed by the user, conversely, if the value displayed in 
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Read-Only field 718 is "False", then the value of the attribute itself may be modified 
by the user as in the exemplary attribute in FIGURES 7. 1 and 7.2. Value field 720 
displays the value of the attribute itself. In FIGURE 7.2, the value of the attribute, 
"False" is contained in an editable form 724. The user may, in the exemplary 
5 attribute of FIGURES 7. 1 and 7.2, change the value of the attribute, and thereby 

change the format for time values. VarType field 722 displays the attribute type, in 
the exemplary illustration of FIGURE 7.2, a Visual Basic Boolean value. The user 
may change the value of an attribute that is not "Read-Only" by entering the new 
value in form 724, as shown, and returning a message to the HTTP server 

10 process 300, FIGURE 3, by invoking the eval and save control 726. The user may 

invoke control 726 by "clicking" on control 726 using, for example, mouse 226, 
FIGURE 2. Restore value control 728 allows the user clear user entered values from 
form 724, and restore values sent down with the form, if any. 

An edit request may be an HTTP request 3 12 in which the value of "duy' has 

1 5 the value "Edit" or other third predetermined value in forming page server 

process 500 that the EDIT service is to be performed. As previously described, field 
"dir 2 " contains an object identifier, in this instance, the identifier of the object whose 
attribute is to be modified. The value in the n dir 3 " field of the url-path of HTTP 
request 312 may identify the attribute field to be modified. In the exemplary attribute 

20 of FIGURE 7.2, the field which may be modified is the attribute value field 712, as 

previously described. Additionally, the new value of the attribute may be included in 
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a query portion of the HTTP request. Thus an exemplary URL may be 
http://server:port/Explorer/edit/objectID/FieldName with query string fieldName = 
valueO & fieldName = valueL In response, the server sets the value of the elements 
of variable "fieldName" (in this example a two element array) to valueO and value 1 . 
Query strings formatted in this way specify named value pairs. However, alternative 
embodiments may be implemented in which the requested function and object ID are 
embedded in the query string, and additionally, may be formatted as an XML query. 
It would be recognized that such alternative embodiments would be within the spirit 
and scope of the present invention. Page server methodology 500 then sends a new 
edit attribute page 512 with the updated value to the client via another step 508. 

Because a tool object model that may be used with the present invention may 
be highly configurable, page server methodology 500 accommodates a variety of 
models configured for various tools and service combinations. In responding to an 
information request, as discussed above in conjunction with step 504, the response 
sent in step 508 passes to the client a few root objects. Other tool objects in the tool 
object model are accessed by exploring parent-child relationships from the root 
objects or the descendants thereof. Child information may be provided by page server 
methodology 500 in response to an HTTP request 312 having a fourth predetermined 
value for "dir/*. In an embodiment of the present invention, the fourth predetermined 
value of "dnV' may be the string "Extend" however other predetermined values may 
be used, as an artisan of ordinary skill would understand. If HTTP request 3 12 
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includes the fourth predetermined value for "dir/ 1 , inspection step 502 passes the 
request to expand step 5 14 which generates and EXTEND model response 516. 
EXTEND model response 516 contains only the child object names and the relation 
to the parent object, identified by the object identifier in field n dir 2 M in the 
corresponding HTTP request 3 12. Additional details about a child object may be 
obtained by invoking information step 504 through an INFO request as described 
hereinabove. 

Thus, for example, consider FIGURE 8.1 illustrating a graphical display 
operable for initiating an EXTEND request. Display 802 illustrates a plurality of 
attributes associated with Generic tool tool 706 described hereinabove in conjunction 
with FIGURES 7.1 and 7.2. Highlighted in display 802 is SECSStandard data 
definition object 804. (SECSStandard data definition objects refer to the SEMI 
Equipment Communications Standard (SECS) promulgated by the SEMI. SECS is 
described further hereinbelow in conjunction with FIGURES 9.1 and 9.2.) If a user 
were interested in the sub definitions of the SECS Standard data definition object 804, 
an embodiment of the present invention, "clicking" on triangle 806 would initiate an 
HTTP request, such as HTTP request 3 12, FIGURE 3, including the third 
predetermined value in field "dirx". Because triangle 806 is associated with 
SECSStandard data definition object 804, the value in field "dir 2 H in the HTTP 
request may be the string "SECSStandard". Although the exemplary display 802 and 
808, FIGURE 8.2, below, are shown with respect to a SECS implementation of tool 
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automation, an artisan would understand that the principles of the present invention 
illustrated thereby may be used in alternative embodiments employing other 
automation protocol. It would also be understood that such alternative embodiments 
would be within the spirit and scope of the present invention. 

In response, inspect function step 502 passes the corresponding HTTP 
request 3 12 to step 5 14 and EXTEND model page 516 generates display 808 
illustrating in FIGURE 8.2 on the users display. Beneath SECStandard data 
definition object 804 appears a plurality of sub definitions 810. 

Additionally, execution of tool object methods may be initiated via page 
server methodology 500. Refer now to FIGURE 9. 1 illustrating a portion of an INFO 
display 902. A directory of methods 904 includes start method 906 (shown 
highlighted) in FIGURE 9.1. In an embodiment of the present invention, start 
method 906 may be a method of the SECS Initiate Processing Service 908. INFO 
display 902 may be used to initiate an INFO HTTP request as previously described 
hereinabove in conjunction with FIGURE 6.1. In response, page server 
methodology 500 passes the request to INFO step 504 which generates an INFO 
page 506 which produces display 910 in FIGURE 9.2. Display 910 includes 
information about a method, for example, description field 912 and service name 
field 914, which, in the exemplary display 910, indicates the SECS initiate processing 
service 908. 
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An artisan of ordinary skill would recognize that the principles of the present 
invention do not rely on the particular detailed information shown in exemplary INFO 
display 910, and it would be further recognized that alternative tool object models 
may include additional information in the corresponding display, or omit some of the 
detailed information included in exemplary display 910. 

Additionally, display 910 includes execute method control 916. In the 
embodiment of FIGURES 9. 1 and 9.2, execute method control 916 may be used to 
initiate processing on a tool. For example, a user by "clicking" on execute method 
control 916 may initiate an HTTP request which is received by page server 
methodology 500. An EXECUTE HTTP request generated in response to user input 
via execute method control 916, may include a fourth predetermined value in field 
"dir! 1 '. In an embodiment of the present invention, the fourth predetermined value 
may be the string "Execute"; however, it would be understood by an artisan of 
ordinary skill that other predetermined values may be used, and such alternative 
embodiments would be within the spirit and the scope of the present invention. 

In response to the fourth predetermined value in the "dky 1 field in the HTTP 
request, inspection step 502 passes the request to execute step 518. In step 518, page 
server process 500 invokes the method 520 corresponding to the objectID received in 
the EXECUTE request whereby a message is sent to the tool corresponding to the 
tool object in the HTTP request, such as HTTP request 3 12. The method 
implementation itself may be supplied by the tool manufacturer or other third party 
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supplier. The tool object may be specified by an object identifier (ID) value in "dir 2 M 
field in the URL-path portion of the HTTP request. In an embodiment of the present 
invention, page server methodology 500 may identify the tool corresponding to the 
objectID via a table maintained on the data processing system executing page server 
methodology 500. 

Method execution may be further understood by referring to FIGURE 5.2 
illustrating remote processing control method 521, which may be one of the plurality 
of methods 520 in FIGURE 5. In step 523, an initiate processing request is sent to the 
tool In step 525, methodology 521 waits for an initiate processing acknowledge from 
the tool. On receipt of the reply, methodology 521, in step 527, awaits for an event 
report from the tool. The creation of an event report, and the display thereof is 
discussed hereinbelow in conjunction with FIGURES 10.1 and 10.2. In step 529, 
following receipt of the event report, sends a message to the tool acknowledging the 
receipt of the event report. If, in step 53 1, processing is complete, methodology 521 
exits. Otherwise, the method loops over steps 527 and 529, until processing 
completes. 

Messages may be sent to the tool using a standard communications protocol, 
for example, the Transmission Control Protocol/Internet Protocol (TCP/IP) via a local 
area network, such as LAN 124, FIGURE 1 . The message format in such an 
embodiment may be specified by the High-Speed SECS Message Services (HSMS) 
specification. The HSMS is promulgated by Semiconductor Equipment and Materials 
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International (SEMI). In such an embodiment, the format of the message sent by the 
method, for example method 521, FIGURE 5.2 may be in accordance with SECS 
encoding in which the message is specified in a two-byte integer format. The first 
byte denotes a category, or "stream", and the second byte defines the function to be 
performed by the tool. For example, the initiate processing request, sent in step 523, 
FIGURE 5.2, may be denoted "S2F27", where the "S" indicates that the first value 
corresponds to the stream, and the second value corresponds to the function. 

In an alternative embodiment, the server implementing page server 
process 500, such as server 101 in FIGURE 1, may communicate with the tool using a 
point-to-point message transfer protocol, such as SECS-L SECS-I is also 
promulgated by SEMI. In such an embodiment, server 101 may be connected to each 
of tools 1 1 1 via an RS-232 serial port. (An artisan of ordinary skill would understand 
that an RS-232 compatible serial port implements signal levels in accordance with the 
RS-232 standard promulgated by the Electronics Industries Association (EIA).) It 
would be recognized by an artisan of ordinary skill that the principles of the present 
invention do not rely on the particular communications protocol used to send 
messages to the tool, and, a protocol in accordance with the HSMS specification or, 
alternatively, SEC-I would be within the spirit and scope of the present invention. 

Although the EXECUTE function has been described in the context of 
initiating processing, particular tool management protocol, such as the GEM standard, 
may provide a plurality of control and monitoring methods. An artisan of ordinary 
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skill would recognize that these may also be invoked using an execute request with 

the corresponding object ID in the "dir 2 " field of the URL. 

Additionally, a method, such as one or more of methods 520, FIGURE 5, 

receives messages from the tools, such as tools 1 1 1 in FIGURE 1. For example, a 
5 " Create Report" method which may be invoked by sending the corresponding HTTP 

request, may define a "report" (a selected set of variables whose values are to be 
?Q reported), link the report to a particular event on the tool and enable that event 

"M whereby a message is sent by the tool on the occurrence of the specified event. As 

described hereinabove, such messages may be received by remote processing method 
p 10 521, and cached by the server performing the method, such as server 110, FIGURE L 

,r Now, recall that in the exemplary display 808 discussed in conjunction with FIGURE 

Jrf 8.2, a plurality of child obj ects 8 1 0 is shown. The plurality of child obj ects 810 

O includes an event reporting object 812. Referring now to FIGURE 10.1, there is 

ig illustrated therein a message history display portion 1020. Display portion 1020 is a 

i?= " 1 5 child object of event reporting object 812, FIGURE 8.2 and may be displayed by 

executing the expand function, step 514 in page server methodology 500, FIGURE 5 

as previously described. Display portion 1020 shows a plurality of message histories 

1022. In the exemplary embodiment of FIGURE 10. 1 in which messages are sent in 

accordance with the SECS-II format, the messages are indicated using the "SmFn" 
20 nomenclature. Message history 1024 corresponds to the initiate processing request 

discussed in conjunction with FIGURES 9. 1 and 9.2. Associated with message 
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history 1024 are a plurality of child objects 1026, These may be displayed as 
illustrated in FIGURE 10. 1 by executing the EXPAND step 5 14 of page server 
methodology 500 by initiating a corresponding HTTP request, as described 
hereinabove in conjunction with FIGURES 8.1 and 8.2. Note that the TED" daughter 
object 1028 and the "MID" daughter object 1030 correspond to values in the 
respective fields shown in message information display 910, fields 916 and 918 
respectively. 

Furthermore, detailed information about messages (messages are objects) may 
be obtained by initiating an information HTTP request, as discussed hereinabove in 
conjunction with FIGURES 6.1 ? 6.2, as well as 9. 1 and 9.2. The corresponding HTTP 
request includes the second predetermined value, for example, "Info" in the "diri" 
field of the url-path portion of the HTTP request, and the object identifier of the 
selected message, for example, one of the corresponding message history, for 
example one of message history 1022, FIGURE 10.1, in the "dir 2 " field of the request 
In response, page server methodology 500 passes the request to step 504, FIGURE 5, 
and a corresponding information page 506 is sent in step 508. FIGURE 10.2 
illustrates information display 1028 corresponding to message history 1024 in an 
embodiment of the present invention in which messages conform to the SECS-II 
specification. However, it would be understood by an artisan of ordinary skill in the 
art that the principles of the present invention embodied in page server methodology 
500 for displaying message information do not rely on the SECS definitions, and 
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other predetermined, message formats may be used in similar fashion. It also would 
be understood by persons of ordinary skill in the art that embodiments of the present 
invention using other such predetermined message formats would be within the spirit 
and scope of the present invention. 
5 The present invention also allows for user customization of methods 

associated with the tool objects. Returning to FIGURE 5, the method invoked by 
execute step 5 18, in response to a corresponding HTTP request, may be a default 
method provided, for example, by the particular tool objection implementation used. 
Alternatively, the present invention provides a mechanism by which the default 

10 mechanism typically compiled code, may be overridden. In FIGURE 1 1, a flowchart 

of override process 1 100 is shown. Override process 1 100 is performed for each 
object in the tool object model. Each object in the tool object model includes a script 
override attribute. This attribute contains script source code. (If the default method is 
to be used for a particular object, the length of the script source may be zero.) In 

1 5 step 1110, for the corresponding object, an override registry list is opened. In an 

embodiment of the present invention, the list may contain a Boolean variable for each 
method associated with the object in which the Boolean value may be initialized to 
"FALSE", indicating that the method has not been overridden. 

If override process 1 100 is being performed on an initialization, or if an 

20 override attribute of an object has been modified by the user, step 1112, the script 

source is parsed in step 1 1 14. In an embodiment of the present invention, the 
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scripting language may be VBScript (Visual Basic Scripting Edition, a scripting 
language developed by Microsoft Corporation). However, other scripting languages 
could be used, and would be within the spirit and scope of the present invention. In 
step 1 1 16, it is determined if the script contains a method having a matching signature 
5 as a default method associated with the object. In an object oriented program 

paradigm, such as that used in the present invention, each method has a name, a return 
type (which specifies a type of a value returned by the method), and, optimally, a set 
of arguments. Taken together, these form the "signature" of the method. If, in 
step 1 1 16, a matching signature is found, then the Boolean value "TRUE" is stored in 

1 0 the object override registry list opened in step 1 1 10 in an entry corresponding to the 

overridden method. If, however, in step 1 1 16, no matching signature is found, then 
the initial Boolean value of "FALSE" remains in the registry list entry, and signals 
that the default method has not been overridden. Override process 1110 then returns 
to step 1 1 12 to determine if the override attribute is subsequently modified. 

1 5 Process 1 100 loops until the override attribute is modified, or a reinitialization has 

occurred. 

In this way, a user can customize methods that act on the tool objects without 
recompiling code. Additionally, the script source code does not need to be parsed 
each time a method is invoked. Returning to FIGURE 5, when execute step 3 18 
20 invokes a method, it refers to the override registry list to determine if the method has 



-34- 



21183-P001US 



PATENT 



been overridden. If not, it invokes the, typically compiled, default method. 
Otherwise, it executes the override script. 

Although the present invention and its advantages have been described 
in detail, it should be understood that various changes, substitutions and alterations 
can be made herein without departing from the spirit and scope of the invention as 
defined by the appended claims. 
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WHAT IS CLAIMED IS: 



1 1 . A tool management method comprising the steps of: 

2 receiving a first request via a network; 

3 determining a type of said first request using a first predetermined field in a 

4 portion of said request; and 

5 sending a first message to a tool in response to said request and said request 

6 type wherein said first message is operable for controlling an action of the tool 

1 2. The method of claim 1 further comprising the step of determining an 

2 identification of a tool object corresponding to said tool using a second predetermined 

3 field in said portion of said request. 

1 3 . The method of claim 1 wherein said tool performs a first action in response to 

2 said message. 

1 4. The method of claim 3 wherein said tool returns at least one second message 

2 associated with said first action, said method further comprising the step of caching 

3 said at least one second message. 
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1 5. The method of claim 4 further comprising the steps of: 

2 retrieving selected ones of said at least one second message; and 

3 generating a response to a second request using said selected ones of said at 

4 least one second message. 

1 6. The method of claim 5 further comprising the step of sending said response to 

2 a client system initiating said first and second requests. 

1 7. The method of claim 1 wherein said first request is transferred in accordance 

2 with a network transfer protocol, and said network transfer protocol defining a format 

3 of said first request. 

1 8. The method of claim 1 further comprising the steps of 

2 receiving a connection request; and 

3 opening a connection to a client, said connection being operable for 

4 communicating requests and responses to said requests. 
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1 9. The method of claim 1 further comprising the steps of: 

2 receiving a second request, said second request selected from the group 

3 consisting of information (INFO) requests, expand requests and edit requests, 

4 wherein, in response to each of said information requests, a set of selected data for a 

5 tool object corresponding to a managed tool is loaded into a WorldWideWeb ("Web") 

6 page for sending to a client, in response to each of said edit requests, a Web page 

7 having portion operable for user entry of one or more values for modifying a tool 

8 object attribute is generated for sending to said client, and in response to each of said 

9 expand requests a set of child object names and relations to a parent object identified 
10 in each expand request is generated for sending to said client. 

1 10. The method of claim 1 wherein said type of said first request denotes an 

2 execute request. 

1 11. The method of claim 1 wherein said step of sending said first message is in 

2 response to execution of a tool object method identified in said first request. 

1 12. The method of claim 1 1 further comprising the step of overriding said tool 

2 object method. 
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1 13 . The method of claim 12 wherein said step of overriding said tool object 

2 method comprises the steps of: 

3 parsing a script source; 

4 determining if said script source includes a method signature matching a 

5 method signature of said tool object method; and 

6 if so, executing a corresponding portion of said script source. 

1 14. The method of claim 7 wherein said transfer protocol is the hypertext transfer 

2 protocol (HTTP), and said first portion corresponds to a first field in a uniform 

3 resource locator (URL) path. 
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1 15. A data processing system comprising: 

2 circuitry operable for receiving a first request via a network; 

3 circuitry operable for determining a type of said first request using a first 

4 predetermined field in a portion of said request; and 

5 circuitry operable for sending a first message to a tool in response to said first 

6 request and said type of said first request wherein said first message is operable for 

7 controlling an action of the tool 

1 16. The data processing system of claim 1 5 further comprising the circuitry for 

2 determining an identification of a tool object corresponding to said tool using a 

3 second predetermined field in said portion of said request 

1 17. The data processing system of claim 15 wherein said tool performs a first 

2 action in response to said message. 

1 18. The data processing system of claim 17 wherein said tool returns at least one 

2 second message associated with said first action, said method further comprising the 

3 step of caching said at least one second message. 
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1 19. The data processing system of claim 1 8 further comprising: 

2 circuitry operable for retrieving selected ones of said at least one second 

3 message; and 

4 circuitry operable for generating a response to a second request using said 

5 selected ones of said at least one second message. 

1 20. The data processing system of claim 19 further comprising circuitry operable 

2 for sending said response to a client system initiating said first and second requests. 

1 21 . The data processing system of claim 1 5 further comprising: 

2 circuitry operable for receiving a connection request; and 

3 circuitry operable for opening a connection to a client, said connection being 

4 operable for communicating requests and responses to said requests. 



-41 - 



21183-P001US 



PATENT 



1 22. The data processing system of claim 1 5 further comprising circuitry operable 

2 for receiving a second request, said second request selected from the group consisting 

3 of information (INFO) requests, expand requests and edit requests, wherein, in 

4 response to each of said information requests, a set of selected data for a tool object 

5 corresponding to a managed tool is loaded into a WorldWideWeb ("Web") page for 

6 sending to a client, in response to each of said edit requests, a Web page having 

7 portion operable for user entry of one or more values for modifying a tool object 

8 attribute is generated for sending to said client, and in response to each of said expand 

9 requests a set of child object names and relations to a parent object identified in each 
1 0 expand request is generated for sending to said client. 

1 23 . The data processing system of claim 1 5 wherein said type of said first request 

2 denotes an execute request. 

1 24. The data processing system of claim 15 wherein said step of sending said first 

2 message is in response to execution of a tool object method identified in said first 

3 request. 

1 25. The data processing system of claim 24 further comprising circuitry operable 

2 for overriding said tool object method. 
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1 26. The data processing system of claim 25 wherein said circuitry operable for 

2 overriding said tool object method comprises: 

3 circuitry operable for parsing a script source; 

4 circuitry operable for determining if said script source includes a method 

5 signature matching a method signature of said tool object method; and 

6 circuitry operable for executing a corresponding portion of said script source, 

7 if so. 
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1 27. A computer program product embodied in a tangible storage medium, the 

2 program product including a program of instructions for performing the steps of: 

3 receiving a first request via a network; 

4 determining a type of said first request using a first predetermined field in a 

5 portion of said request; and 

6 sending a first message to a tool in response to said first request and said type 

7 of said first request, wherein said first message is operable for controlling an action of 

8 the tool. 

1 28. The program product of claim 27 further comprising instructions for 

2 performing the step of determining an identification of a tool object corresponding to 

3 said tool using a second predetermined field in said portion of said request. 

1 29. The program product of claim 27 wherein said tool performs a first action in 

2 response to said message. 

1 30. The program product of claim 29 wherein said tool returns at least one second 

2 message associated with said first action, said method further comprising the step of 

3 caching said at least one second message. 



-44- 



21183-P001US 



PATENT 



1 31. The program product of claim 3 0 further comprising instructions for 

2 performing the steps of: 

3 retrieving selected ones of said at least one second message; and 

4 generating a response to a second request using said selected ones of said at 

5 least one second message. 

1 32. The program product of claim 3 1 further comprising instructions for 

2 performing the step of sending said response to a client system initiating said first and 

3 second requests. 

1 33 . The program product of claim 27 further comprising instructions for 

2 performing the steps of 

3 receiving a connection request; and 

4 opening a connection to a client, said connection being operable for 

5 communicating requests and responses to said requests. 
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1 34. The program product of claim 27 further comprising instructions for 

2 performing the step of receiving a second request, said second request selected from 

3 the group consisting of information (INFO) requests, expand requests and edit 

4 requests, wherein, in response to each of said information requests, a set of selected 

5 data for a tool object corresponding to a managed tool is loaded into a 

6 WorldWideWeb ("Web") page for sending to a client, in response to each of said edit 

7 requests, a Web page having portion operable for user entry of one or more values for 

8 modifying a tool object attribute is generated for sending to said client, and in 

9 response to each of said expand requests a set of child object names and relations to a 
10 parent object identified in each expand request is generated for sending to said client. 

1 35. The program product of claim 27 wherein said type of said first request 

2 denotes an execute request. 

1 36. The program product of claim 3 5 wherein said instructions for performing the 

2 step of sending said first message are performed in response to execution of a tool 

3 object method identified in said first request. 

1 37. The program product of claim 3 6 further comprising instructions for 

2 performing the step of overriding said tool object method. 
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1 38. The program product of claim 3 7 wherein said instructions for performing the 

2 step of overriding said tool object method comprises instructions for performing the 

3 steps of: 

4 parsing a script source; 

5 determining if said script source includes a method signature matching a 

6 method signature of said tool object method; and 

7 if so, executing a corresponding portion of said script source. 
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APPARATUS AND METHOD FOR WEB-BASED TOOL MANAGEMENT 

ABSTRACT OF THE DISCLOSURE 

A method and apparatus for web-based tool management are implemented. A 
tool object model provides a logical representation of the physical tool. The tool 
object model defines a hierarchical set of tool objects that characterize the tool, and 
additionally a set of method for performing actions on the tool objects. These actions 
also correspond to operations, which may include reporting as well as processing 
tasks, performed by the tool. A user may remotely control and monitor a tool using a 
conventional web browser. For example, a user may execute methods of the tool 
object model, or obtain detailed information about a tool object. User actions are 
passed to a server by embedding them in hypertext transfer protocol (HTTP) requests. 
The server receives the HTTP request, and passes the request to a corresponding page 
server in accordance with the action requested. Depending on the action requested, 
the page server may generate a web page in response, or may invoke a method of the 
tool object model. 

: :ODMA\PCDOCS\AUSTIN_l\l 31 935U 
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